package com.leetcode.array;

import java.util.ArrayList;
import java.util.List;

/**
 * 78. 子集
 * 给你一个整数数组nums ，数组中的元素 互不相同 。返回该数组所有可能的子集（幂集）。
 * 解集 不能 包含重复的子集。你可以按 任意顺序 返回解集。
 * 示例 1：
 * 输入：nums = [1,2,3]
 * 输出：[[],[1],[2],[1,2],[3],[1,3],[2,3],[1,2,3]]
 * 示例 2：
 * 输入：nums = [0]
 * 输出：[[],[0]]
 * 提示：
 * 1 <= nums.length <= 10
 * -10 <= nums[i] <= 10
 * nums 中的所有元素 互不相同
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode-cn.com/problems/subsets
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */
class Code78 {
    public static void main(String[] args) {
        int[] nums = new int[]{1,2,3};
        Code78 code = new Code78();
        List<List<Integer>> subsets = code.subsets(nums);
        System.out.println(subsets);
    }
    List<List<Integer>> list = new ArrayList<>();
    List<Integer> temp = new ArrayList<>();
    public List<List<Integer>> subsets(int[] nums) {
        way(nums,0);
        return list;
    }
    public void way(int[] nums,int k){
        if(k >= nums.length){
            list.add(new ArrayList<>(temp));
            System.out.println(temp);
            return;
        }
        temp.add(nums[k]);
        way(nums,k+1);
        temp.remove(temp.size()-1);
        way(nums,k+1);
    }


}
